package cn.tedu.sp02.item.controller;

import cn.tedu.sp01.pojo.Item;
import cn.tedu.sp01.service.ItemService;
import cn.tedu.web.util.JsonResult;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;
import java.util.Random;

@RestController
@Slf4j
public class ItemController {
    @Autowired
    private ItemService itemService;

    // 获取订单商品列表
    @GetMapping("/{orderId}")
    public JsonResult<List<Item>> getItems(@PathVariable String orderId) throws InterruptedException {
        /*
        JsonResult - 响应结果的封装对象
                     - code: 响应的状态码，可以是http状态，或者也可以自己任意定义
                     - msg: 提示消息
                     - data: 发回的响应数据对象
         */
        List<Item> items = itemService.getItems(orderId);

        // 为了测试响应超时失败，添加随机延迟代码
        if (Math.random() < 0.9) {
            // 90%概率执行延迟代码
            int t = new Random().nextInt(5000); //随机时长0到5秒
            System.out.println("延迟： "+t);
            Thread.sleep(t);
        }

        return JsonResult.ok().data(items);
    }

    // 减少商品库存
    /*
    客户端发送的请求协议，商品集合要包含在请求协议体中，
    @RequestBody 是完整接收请求协议体数据

    协议头：
    http 1.1 /decreaseNumber
    aaa: aaa
    bbb: bbb

    协议体：
    [{id:23, name:xxx, number:2}, {}, {}]
     */
    @PostMapping("/decreaseNumber")
    public JsonResult<?> decreaseNumber(@RequestBody List<Item> items) {
        itemService.decreaseNumber(items);
        return JsonResult.ok().msg("减少商品库存成功");
    }
}
